IN THE CLAIMS: 



Please amend claims 1, 4, 26-28, 32, 33, and 35 as follows. 

1. (Currently Amended) A switch for a packet switched or frame switched 
network, said switch having conventional routing circuitry, said network having client 
devices and storage devices and a storage manager that decides to redirect read and/or 
write transactions on any basis so as to virtualize said storage devices, said switch 
comprising: 

one or more ports which are structured to operate to receive one or more 
redirection commands from said storage manager or another switch in said network 
coupled to said storage manager containing old address data and new address data, said 
ports containing circuitry to store said old address data and new address data in one or 
more look up tables, said switch containing circuitry functioning to compare packet or 
frame type information included in a header of at least some packets or frames arriving at 
a port coupled to a client device or a storage device to determine if the packet or frame is 
of a type which is to be relabeled and redirected, and, if the packet or frame is of a type to 
be relabeled and redirected, comparing at least some of the old address data therein to the 
old address data entries for one or more redirection commands stored in one or more of 
said look up tables, and if there is a match to any of the old address data of said one or 
more redirection commands, relabelling said packet or frame by substituting the 
corresponding new address data from said matching redirection command(s) for said old 
address data in said packet or frame header, said new address data b e ing such as to caus e 



V causing said relabeled packet or frame to be routed so as to bypass said storage manager 
V but to look like it came from said storage manager, and then passing said relabeled packet 

^ or frame to said conventional routing circuitry for forwarding to the destination identified 
in said new address data, and wherein the sequence in which the type of incoming packet 
is determined and the old address data lookup is performed is not critical. 

2. (Original) The apparatus of claim 1 wherein each said port contains its own 
redirection circuitry and its own look up table for storing redirection commands, said 
redirection circuitry in every port being structured to receive first and second redirection 
commands for every write transaction to be redirected and to use configuration data 
defining which switch ports are coupled to which devices, said configuration data being 
stored in said switch or received in a message from said storage manager and said 
configuration data being used to forward said first redirection command to a first port of 
said switch coupled to the client device which originated said write request for storage in 
a look up table, and to forward the second redirection command to a second port coupled 
to the storage device which is to store the data to be written for storage in a look up table, 
said redirection circuitry being structured to receive a redirection command for every 
read transaction to be redirected and to use configuration data to forward said redirection 
command to a third port coupled to the storage device where the requested data is stored 
for storage in a look up table, 
j 3. (Original) The apparatus of claim 1 wherein each said port contains its own 

redirection circuitry and its own look up table for storing redirection commands, said 



redirection circuitry in every port being structured to receive first and second redirection 
commands for every write transaction to be redirected and to forward said first and 
second redirection commands to all ports of said switch for storage in the look up tables 
of said ports, said redirection circuitry also being structured to receive a redirection 
command for every read transaction to be redirected and to forward said redirection 
command to all ports of said switch for storage in a look up table in said third port. 

4. (Currently Amended) The apparatus ot claim 1 wherein eacn said port contains 
its own redirection circuitry, said redirection circuitry in every port being structured to 
receive a first and second redirection commands for every write transaction to be 
redirected and to to forward said first and second redirection commands to a shared look 
up table in said switch to which all redirection circuits in all ports have access, said 
redirection circuitry also being structured to receive a redirection command for every 
read transaction to be redirected and to forward said redirection command for storage in 
said shared look up table. 

5. (Original) The apparatus of claim 1 wherein said switch contains shared 
redirection circuitry that performs the redirection process and a shared look up table for 
storing redirection command used by said shared redirection circuitry to perform said 
redirection process, and wherein each said port contains circuitry to store redirection 
commands in said shared look up table by any method, and to forward frames or packets 
to said shared redirection circuitry for analysis and relabelling if said frames or packets 
are to be redirected. 




6. (Original) A virtualizing storage manager for a packet switched or frame 
switched network, said network having client devices and storage devices and a switch 
having any structure capable of redirecting read and/or write transactions based upon 
commands from said storage manager so as to virtualize said storage devices, said storage 
manager comprising: 

conventional storage manager circuitry to carry out conventional processing of 
read and/or write transactions that are not redirected; and 

a computer programmed to or logic circuitry structured to decide whether to 
redirect packets or frames of a read or write transaction based upon any redirection 
criterion, and programmed or structured to generate and send at least one said redirection 
command to a switch in said network for every read or write transaction to be redirected, 
and programmed or structured to send a corresponding read or write request to the 
appropriate storage device for every received read or write request from a client device to 
start the transaction, and programmed or structured to send at least one purge command 
to a switch in said network which stored said. redirection commands in one or more look 
up tables, said at least one purge command corresponding to one or more completed read 
or write transactions that have been redirected by said switch to cause said switch to 
purge from said one or more look up tables the redirection command or commands 
pertaining to said one or more read or write transaction that has been completed. 

7. (Original) The apparatus of claim 6 wherein said storage manager makes a 
decision based upon programmable redirection criteria. 
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8. (Original) The apparatus of claim 6 wherein said storage manager makes a 
decision whether or not to redirect data and transfer ready packets or frames of a 
particular read or write request based upon redirection criteria that is that every packet or 
frame of a data or transfer ready type which is part of a read or write transaction is to be 
redirected. 

9. (Original) The apparatus of claim 6 wherein said storage manager makes a 
decision whether or not to redirect data and transfer ready packets or frames of a 
particular read or write request based upon redirection criteria that is that every packet or 
frame of a data or transfer ready type which is part of a read or write transaction is to be 
redirected when the number of outstanding read and/or write requests is greater than or 
equal to a threshold. 

10. (Original) The apparatus of claim 9 wherein said threshold is programmable. 

1 1 . (Original) The apparatus of claim 6 wherein said storage manager makes a 
decision whether or not to redirect data and transfer ready packets or frames of a 
particular read or write request based upon redirection criteria that is that every packet or 
frame of a data or transfer ready type which is part of a read or write transaction is to be 
redirected when the number of outstanding read and/or write requests is such that a 
measured latency between receipt of a read or write request and completion of the 
corresponding read or write transaction is greater than a threshold latency. 

12. (Original) The apparatus of claim 6 wherein said storage manager makes a 
decision whether or not to redirect data and transfer ready packets or frames of a 



1 



particular read or write request based upon redirection criteria that is that every packet or 
frame of a data or transfer ready type which is part of a read or write transaction is to be 
redirected when said storage manager decides based upon any type criteria or any type 
measurement that it has become a bottleneck. 

13. (Original) The apparatus of claim 6 wherein said storage manager makes a 
decision whether or not to redirect data and transfer ready packets or frames of a 
particular read or write request based upon redirection criteria that is that every packet or 
frame of a data or transfer ready type which is part of a read or write transaction is to be 
redirected when the count of a counter which was started when a read or write request 
from a client device was received and stopped when the read or write transaction 
corresponding to said request has been completed exceeds a predetermined threshold. 

14. (Original) The apparatus of claim 13 wherein said predetermined threshold is 
a number read from a look up table which stores threshold values based upon the size of 
the tread or write transaction, and wherein said means for deciding performs the 
following steps: 

(1) analyzing each read or write request to determine the size of the transaction 
and retrieves the appropriate latency threshold value from said look up table based upon 
the size of the read or write transaction; 

(2) starting a counter when said read or write request was received; 

(3) perform conventional read or write transaction processing including sending a 
read or write command to the appropriate storage device and including forwarding data 
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and transfer ready frames to the client or storage device as appropriate to the particular 
type of transaction being performed; 

(4) stop said counter when said conventional read or write transaction was 
completed; 

(5) comparing the counter value when the transaction was completed to the 
threshold number looked up from said look up table as a measure of the time it took to 
complete the conventional read or write transaction; and 

(6) if the time taken to complete the conventional read or write transaction 
exceeded the threshold, generating one or more redirection commands for subsequent 
read or write requests and sending them to the switch; 

(7) performing any method of stopping redirection after some time passes and 
resuming the latency measuring process of steps (1) through (6) for subsequent read or 
write requests until a latency threshold value is again exceeded, and then repeating steps 
(6) and (7). 

15. (Original) The apparatus of claim 14 wherein step (7) comprises continuing 
redirection for a fixed or programmable amount of time, and then ceasing redirection and 
resuming performance of steps (1) through (6) for subsequent read or write requests until 
a latency threshold value is again exceeded, and then repeating steps (6) and (7). 

16. (Original) The apparatus of claim 14 wherein step (7) comprises continuing 
redirection for all subsequent read or write requests except every Xth read or write 
request where X is any integer and carrying out conventional read or write transaction 
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processing as appropriate for every Xth read or write request and measuring the latency 
of said Xth request by performance of steps (1) through (6), and if the latency threshold 
has not been exceeded by said Xth request, resuming performance of steps (1) through 
(6) for subsequent read or write requests until a latency threshold value is again 
exceeded, and then repeating steps (6) and (7). 

17. (Original) The apparatus of claim 6 wherein said storage manager makes a 
decision whether or not to redirect data and transfer ready packets or frames of a 
particular read or write request based upon redirection criteria that is that every packet or 
frame of a data or transfer ready type which is part of a read or write transaction that 
exceeds a certain size as determined from the original read or write request is to be 
redirected. 

18. (Original) The apparatus of claim 6 wherein said storage manager includes a 
cache memory and a cache algorithm that managers said cache memory, and wherein said 
storage manager makes a decision whether or not to redirect data and transfer ready 
packets or frames of a particular read or write request based upon whether the requested 
data is already stored in said cache memory in said storage manager, or makes a decision 
whether or not to redirect a read transaction based upon whether said storage manager 
cache algorithm wants to copy the data of the read request into said cache memory in said 
storage manager. 

19. (Original) The apparatus of claim 1 wherein each port of said switch is 
structured to receive redirection commands either from an external source or from a 
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source internal to the switch such as the routing circuitry and store all said redirection 
commands in a look up table maintained by said port and use said look up table to do all 
necessary relabelling and redirection operations. 

20. (Original) A switch for a packet switched or frame switched network, said 
switch having conventional routing circuitry, said network having client devices and 
storage devices and a storage manager coupled to said switch, said switch comprising: 

one or more ports which are structured to operate to receive redirection commands 
from a storage manager containing old address data and new address data and to store the 
old address data and new address data contained therein in a shared look up table, but 
otherwise to function as conventional switch ports; 

shared redirection interface circuitry coupled to each of said ports and said shared 
look up table and coupled to said-conventional routing circuitry, said shared redirection 
interface circuitry structured to compare packet or frame type information included in a 
header of each packet or frame arriving from a port coupled to a client device or a storage 
device to determine if the packet or frame is^ of a type which is to be relabeled and 
redirected, and, if the packet or frame is of a type to be relabeled and redirected, then 
comparing the old address data therein to the old address data in said shared look up 
table, and if there is a match to any of the old address data entries in said look up table, 
substituting the corresponding new address data from said look up table, and forwarding 
said packet or frame to said conventional routing circuitry for routing. 

21. (Original) A packet switched or frame switched network, comprising: 
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one or more client devices; 
one or more storage devices; 

a storage manager having redirection circuitry functioning to receive read or write 
transaction requests from said one or more client devices and redirect at least some of 
said read and write transaction requests issued by said client devices by issuing 
redirection commands which contain old address data and new address data which will 
cause relabelling of data and transfer ready frames so that they are routed between said 
client device which issued said request and the storage device which is to be read from or 



a corresponding read or write request to the appropriate storage device for every received 



read or write request from a client device to start the transaction, said re^irecHon^circm^ 



also functioning to receive status packets or frames indicating particular read or write 
transactions that have been redirected have been completed and for issuing purge 
commands which function to cause purging of old address and new address data of 
redirected read or write transactions that have been completed; 

one or more switches, each having conventional routing circuitry and each further 
comprising: 

a shared lookup table; 

a shared redirection interface circuit; 

one or more ports which are structured to operate to receive redirection commands 
from said storage manager or another switch and to store the old address data and new 



written to so as to bypass said storage manager, 
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address data contained therein in said shared look up table, and structured to receive said 
purge commands and to use the information therein to purge obsolete old address data 
and new address data from said shared look up table for read or write transactions that 
have been completed, but otherwise to function as conventional switch ports; 



and wherein said (gha re^^ circuitry coupled to each of said 

ports and said shared look up table and coupled to said conventional routing circuitry, 
said shared redirection interface circuitry structured to compare packet or frame type 
information included in a header of each packet or frame arriving from a port coupled to 
a client device or a storage device to determine if the packet or frame is of a type which is 
to be relabeled and redirected, and, if the packet or frame is of a type to be relabelled and 
redirected, then comparing the old address data therein to the old address data in said 
shared look up table, and if there is a match to any of the old address data entries in said 
look up table, substituting the corresponding new address data from said look up table, 
and forwarding said packet or frame to said conventional routing circuitry for routing; 
and 



judata path coupling each said client devices, storage devices and said^ storag e 
^manager tojat least one of said one or more switches and coupling said one or more 
switches together. 

22. (Original) A packet switched or frame switched network, comprising: 
one or more client devices; 
one or more storage devices; 
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a storage manager having redirection circuitry functioning to receive read or write 



.write transaction requests jfesued by said client devices by issuing redirection commands 



which contain old address data and new address data which will cause relabelling of data 
and transfer ready frames so that they are routed between said client device which issued 
said request and the storage device which his to be read from or written to so as to bypass 
said storage manager, said redirection circuitry also for sending a corresponding read or 
write request to the appropriate storage device for every received read or write request 
from a client device to start the transaction, said redirection circuitry also functioning to 
receive status packets or frames indicating particular read or write transactions that have 
been redirected have been completed and for issuing purge commands which function to 
cause purging of old address and new address data of redirected read or write transactions 
that have been completed; 

one or more switches each having conventional routing circuitry and each further 
comprising one or more ports 

and wherein at least the ports coupled to said storage manager or another switch 
being structured to operate to receive one or more redirection commands from said 
storage manager or another switch in said network coupled to said storage manager 
containing old address data and new address data and store said old address data and new 
address data in one or more look up tables and to receive purge commands from said 
storage manager or another switch in said network and use the information therein to 



requests from said one or more client devices and redirect at least some of said^read and 
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purge old and new address data pertaining to redirected read or write transactions that 
have been completed from said one or more look up tables, 

each said switch containing redirection circuitry functioning to compare packet or 
frame type information included in a header of at least some packets or frames arriving at 
a port coupled to a client device or a storage device to determine if the packet or frame is 
of a type which is to be relabelled and redirected, and, if the packet or frame is of a type 
to be relabelled and redirected, then comparing the old address data therein to the old 
address data entries in said look up table3, and if there is a match to any of the old 
address data entries in said one or more look up tables, substituting the corresponding 
new address data from said look up table for said old address data in said packet or frame 
header and passing said packet or frame to said conventional routing circuitry for 
forwarding to the destination identified in said new address data, at least the port; and 

a data path coupling each said client devices, storage devices and said storage 
manager to at least one of said one or more switches and coupling said one or more 
switches together. 

23. (Original) The apparatus of claim 21 or 22, wherein said redirection circuitry 
in said storage manager includes means to decide which read and/or write transactions to 
redirect based upon predetermined redirection criteria which could be a single criteria or 
any one of a plurality of different criteria, said criteria being either fixed or 
programmable, and which particular criteria is used can be fixed or configurable. 
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24. (Original) The apparatus of claim 22 wherein said one or more look up tables 
comprise a look up table in each port and wherein said redirection circuitry comprises a 
redirection circuit in every port. 

25. (Original) The apparatus of claim 22 wherein said one or more look up tables 
comprise a look up table in each port and wherein said redirection circuitry comprises a 
redirection circuit in every port, and wherein said redirection circuitry in said storage 
manager includes means to decide which read and/or write transactions to redirect based 
upon predetermined redirection criteria which could be a single criteria or any one of a 
plurality of different criteria, said criteria being either fixed or programmable, and which 
particular criteria is used can be fixed or configurable. 



26. (Currently Amended) A switch for a packet or frame switched network 
including one or more client devices and one or more storage devices and a storage 
manager server, said switch having conventional routing circuitry and means for 
receiving and storing redirection commands from said stoTrage manager server and for 
sending a corresponding read or write request to the appropriate storage device identified 
in the original destination address information for every received read or write request 
received from a client device to start the a transaction, and for comparing address data of 
selected frames or packets arriving at said port to stored redirection data from said 
redirection commands and for readdressing said selected frames or packets which match 
any stored redirection command by putting information in headers of said selected frames 
or packets which will cause said switch to transmit said selected frames or packets to the 
device identified in the destination address of the original frame or packet header 
information and bypass said storage manager server but make said redirected frames or 
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packets look like they came from said storage manager server, and sending said selected^ 
readdressed packets or frames to the destination address identified in the new header data 
so as to bypass said storage manager server, and for receiving purge commands from said 
storage manager server and purging old address data and new address data identified in 
said purge commands of redirection commands issued for transactions that hav^been 
completed. 

27. (jCurrently Amended) A storage manager for a packet or frame switched 
network including one or more client devices and one or more storage devices and a 
switch, said storage manager including: 

means for receiving read or write transaction requests from said one or more client 



devices and mapping the destination address data designated in each<Iak^ead or write 



requesj) to a storage device, and, for each (Smd^e ad or wri te requesp sending a 



corresponding(read\or write request to said storage device identified in said destination 
address to start the aVransaction; and 

means for using redirection criteria to decide which 'read and write requests from said 
client devices to redirect, and for generating and sending redirection commands to said 
switch for the read arid write requests to be redirected, said redirection commands 
containing old address data and new address data which will cause data and transfer 
ready frames of read amd write transactions to be redirected to have the header 
information thereof altered! so that they are routed by said switch to bypass said storage 
manager but look like they dame from said storage manager; and 

means for receiving status ijrames or packets and for issuing purge commands to said 
switch when said status frames or packets indicate a read or write transaction which has 
been redirected has been completed, said purge commands for causing said switch to 
purge from one or more look ufo tables in said switch old address data and new address 
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data identified in said purge commands of redirection commands previously issued for 
transactions that have been completed. 

28. (Currently Amended) A packet or frame switched network including one or 
more client devices and one or more storage devices each of which is coupled to a packet 
or frame switch comprising: 

a switch having conventional routing circuitry therein, said switch comprising: 
one or more ports in said switch, said switch including redirection circuitry 
structured to operate to receive redirection commands from a storage manager and to 
store the redirection address data containing old address data and new address data 
contained therein in a look up table, said redirection circuitry also structured to receive 
incoming packets or frames and determine if they are data or transfer ready type frames 



or packets and, if not to transfer s aid^packet^ or fram^ to said^conventional routing 
circuitry^but if so, to compare the address data therein to the old address data in said look 
up table, and, if there is a match to any of the old address data in said look up table, 
functioning to substitute the new address data from said look up table from the entry 
which includes old address data that matched the address data in the incoming packet or 



frame and pass the packet or frame to said conventional routing circuitry^ and 

a storage manager comprising a one or more port adapter circuits, a memory and a 
microprocessor coupled to ^dfmemory^knd programmed to receive read or write 



requests from^nd_onewj devices)and map the data designated ii/said read or 

write request) to a particular storage device and to send corresponding read or write 
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requests to said storage device to start the transaction, and programmed to determine 
from the frame or packet header information of said read or write request the specific 
^ client device from which the request came and how large the a transaction is 5 and, if the 
transaction is larger than a redirection size criteria, for generating and sending one or 
more redirection commands to said switch for storage in at least one look up table 




maintained therein, ^aid re direction comma nd,) containing old address data and new 
address data that will cause said switch to receive data and transfer ready frames for 
transactions to be redirected to relabel said packet or frame with new address data so that 



(said data or transfer ready frames will be routed by said switch so as to bypass said 



storage manager but look like they came from said storage manager, and for performing 
conventional processing on any read or write request that is not to be redirected, and 
programmed or structured to monitor status frames to determine when a redirected 
transaction has been completed and sending purge commands to said switch to purge the 
old and new address data from said look up table for read and write transactions that have 
been completed; and 

a data path coupling said switch to said storage manager and to said client and 
storage devices. 

29. (Original) The apparatus of claim 28 wherein each said port maintains its 
own redirection circuitry and its own look up table storing redirection commands, and 
wherein said microprocessor in said storage manager server looks up the specific port to 
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which a specific storage device involved in a transaction is coupled and/or the specific 
port to which the client device involved in a specific transaction is coupled and sends said 
one or more redirection commands for the transaction only to the appropriate specific 
port. 

30. (Original) The apparatus of claim 28 wherein each said port maintains its 
own look up table storing redirection commands, and wherein said microprocessor in said 
storage manager server sends all said redirection commands to all ports in said switch and 
wherein each port includes redirection circuitry to store redirection commands in the 
port's look up table and use the data therein to relabel for redirection data and transfer 
ready frames. 

31. (Original) The apparatus of claim 28 wherein said switch maintains a shared 
look up table storing all redirection commands received from said storage manager, said 
shared look up table for use by all ports, and wherein said microprocessor in said storage 
manager sends all said redirection commands to a port to which said storage manager 
server is coupled with instructions to forward said redirection command for storage in 
said shared look up table, and wherein each said port of said switch has circuitry to use 
said shared look up table to determine if an incoming frame or packet needs to be 
relabelled for redirection and at least the ports coupled to said storage manager include 
circuitry to store all said redirection commands in said shared look up table. 
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32. (Currently Amended) The apparatus of claim 28 wherein said microprocessor 
in said storage manager server is programmed to sum the number of outstanding read 
requests that have not yet been fulfilled, and only issues redirection commands when the 
number of outstanding read requests exceeds a threshold which is either fixed or 
programmable and said size number is greater than said redirection size criteria. 

33. (Currently Amended) The apparatus of claim 28 wherein said microprocessor 
in said storage manager server is programmed to monitor the time between receipt of a 
read or write request and completion thereof, and only issues redirection commands when 
the time to fulfillment exceeds a threshold which is either fixed or programmable and the 
a size of said transaction is greater than said redirection size criteria. 



34. (Original) A packet or frame switched network including one or more client 
devices and one or more storage devices, each of which is coupled to a packet or frame 
switch, comprising: 

a switch having conventional routing circuitry therein and further comprising: 

shared redirection circuitry; 

a shared look up table; 

one or more ports in said switch which are structured to operate to receive 
relabelling and redirection and purge commands from a storage manager and to forward 
them(^saia'~sha^ for storage in said shared look up table and 
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structured to forward data and transfer ready frames to said shared redirection circuitry 
and to forward all other types of packets or frames to said conventional routing circuitry; 



and wherein ( said shar ecir edirectior^ circuit includes circuitry to receive said 
redirection commands and store them in said shared look up table and to receive 
incoming data or transfer ready packets or frames from said ports and compare the 
address data therein to the old address data in said look up table, and, if there is a match 
to any of the old address data in said look up table functioning to substitute the new 
address data from the matching entry in said look up table for the old address data in the 
incoming packet or frame and pass the packet or frame to said conventional routing 
circuitry, said shared redirection circuit also structured to receive said purge commands 
and use the information therein to purge from said shared look up table the old and new 
address data of redirection commands for completed read or write transactions; and 

a storage manager including conventional cache memory and circuitry 
programmed or structured to receive read or write requests from said one or more client 
devices identifying specific data to be read and to map the identified data to a storage 
device and, for each read or write request, send a corresponding read or write requests to 
said storage device to get the transaction started, and for storing the most^frequently 
requested data blocks from read transactions in said cache memory and programmed or 
structured to monitor read requests for read requests for blocks of data that are stored in 
said cache memory, and, if a requested block of data is stored in said cache memory, for 
sending the requested data from the cache memory back to the client device which 
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requested the data instead of sending a read request to a storage device that stores the 
requested data, and further comprises circuitry to decide whether to redirect a particular 
read or write request based upon fixed or programmable redirection criteria, and 
programmed or structured to determine from the frame or packet header information of 
said packet or frame the specific client device from which the request came, and, if said 
read or write request is not to be redirected, for performing conventional processing to 
complete said read or write request, but if said read or write request is to be redirected, 
for generating and sending one or more redirection commands to said switch for storage 
in said shared look up table maintained therein, said redirection command containing old 
address data and new address data that will cause said shared redirection circuitry that 
receives a data or transfer ready packet or frame that is part of the transaction to be 
redirected to relabel said packet or frame with new address data and forward said packet 
or frame to said conventional routing circuitry such that said packet or frame gets routed 
so as to bypass said storage manager but so as to look like it came from said storage 
manager, and programmed or structured to monitor status frames to determine when a 
redirected transaction has been completed and sending purge commands to said switch to 
purge the old and new address data from said shared look up table for read and write 
transactions that have been completed; and 

a data path coupling said switch to said client and storage devices and to said 
storage manager. 
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35. \(Currently Amended) A packet or frame switched network including one or 
more client fflevices and one or more storage devices, comprising: 

a data oath coupled to said client devices and said storage devices; 

a storaga manager coupled to said data path; 

a switch rtaving conventional routing circuitry and including: 

one or more ports in said switch which contain redirection circuitry to receive 
relabelling and redirection commands from a storage manager and to store the redirection 
address data containing old address data and new address data contained therein in at 
least one look up tabid and to receive incoming data and transfer ready packets or frames 
and comparing the addless data therein to the old address data in ^idjoo k^up^abl e^nd to 
compare packet or frame type information included in a header of said packet or frame, 
and, if there is a match to any of the old address data in said look up table and the type 
information matches the types of packets or frames that are to be redirected, functioning 
to substitute at least the new address data from said look up table from the entry which 
includes old address data that matched the address data in the incoming packet or frame 



and pass the packet or framfe to fsaidco nventional routing circuitr y) and performing 
conventional processing to routl^ all other packets or frames to said conventional routing 
circuitry; and 



whereiri(said storage manger includes: 



means for receiving write a\id read requests from any of said ^ne' or more client 
devices identifying specific data to b\^ read or written and for mapping said read and write 
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requests to particular storage devices, and for sending corresponding read or write 
request^ to said storage devices to get the a transaction started, and for determining if the 
transacti&n is to be redirected, and, if not, for performing conventional processing to 
complete me transaction, but if said transaction is to be redirected, for analyzing said read 
and write requests to determine how many blocks of data are to be read or written, and, if 
the number df blocks is greater than a threshold, which can be fixed or programmable, for 
mapping the requested blocks to a storage device which stores the requested data and for 
generating and Vending one or more redirection commands to said switch for storage in 
said at least one\ook up table maintained therein, ^aid jedirection com mand^ containing 
old address data and new address data that will cause the redirection circuitry in the port 
that receives a dataW transfer ready packet or frame to relabel said packet or frame with 
new address data that will cause said packet or frame to be routed by said conventional 
routing circuitry so as to bypass said storage manager but look like it came from said 
storage manager, and\for monitoring status packets or frames to determine when a 
redirected transaction his been completed and sending purge commands to said switch to 
purge the old and new acMress data from said at least one look up table for read and write 
transactions that have been completed. 



36. (Previously Amended) A process of redirecting selected types of data frames 
or packets which are part of a read transaction between a client computer and a storage 
device in a packet or frame switched network including a storage manager, one or more 
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client computers, one or more storage devices and a packet or frame switch, comprising 
the steps: 

1) receiving at said storage manager from a client computer one or more read 
requests; 

2) receiving at said packet or frame switch from said storage manager at least one 
redirection command to redirect selected types of data frames or packets which are part 
of a read transaction to be redirected and storing said redirection commands; 

3) transmitting corresponding read requests from said storage manager to one or 
more storage devices identified in said read requests originally received by said storage 
manager so as to start the read transaction; 



4) responding to (said read requests^ said one or more storage devices which 



received said one or more read requests transmitted by said storage manager by 
transmitting frames or packets addressed to said storage manager via said switch, said 
frames or packets containing the requested data; and 

5) in said switch, receiving said frames or packets of data transmitted by said one 
or more storage devices in response to said one or more read requests, and, if a 
redirection command is stored for a read transaction to be redirected of which said 
packets or frames are a part of which were received from said one or more storage 
devices as a result of step 4, changing the header of the frames or packets of said packets 



or frames to be redirected so as to reroute them through said switch tojsaid one or more 
client devices/which made said read requests in step 1 so as to bypass said storage 
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manager but relabelling the headers of said frames or packets to be rerouted such that the 
rerouted packets or frames appear to originate from said storage manager. 

37. (Previously Amended) A process of redirecting selected frames or packets 
which are part of read transaction between a client device which is requesting data and 
which transmitted a read request to a storage manager via a packet or frame switch 



requesting data from aCstXSrage device which stores the requested data, saidQhent and 
S torage d eyigs^and storage manager and switch all being in a packet or frame switched 
network, ^Tdpro ce^ carried out in ^Sdswkch^id comprising the steps: 

receiving from said storage manager at said packet or frame switch one or more 
redirection commands to redirect the data frames or packets which are responses to said 
read request originated by said client device and storing said one or more redirection 
commands; and 



receiving frames or packets transmitted by said storage device ^said client device 




as part of said ^ead^tran^ be redirected, and, if a redirection command is stored 
for said read transaction to be redirected and (§ajd receive frames or packets^re part of 
said read transaction to be redirected and are the p articular ty pesjpf packets or frames that 
should be redirected, changing the header of each of the received frames or packets of 
said ^rticularjype^) that should be redirected so as to reroute said particular types of 
frames or packets through said switch so as to bypass said storage manager but 
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relabelling the headers thereof such that the rerouted packets or frames appear to 
originate from said storage manager. 

38. (Previously Amended) A process for controlling redirection of selected data 
frames or packets of selected types which are part of a read transaction between a client 



device and a storage device in a packet or frame switched network wherein ^ai dclienT ^ 
f^devi^ be redirected by transmitting a read request to a 



storage manager via a switch requesting data from a particular storage device^^said" 
process)carried out in said storage manager and comprising the steps: 

receiving at said storage manager from a client computer one or more read 
requests; 

composing and transmitting to said packet or frame switch redirection commands 
to redirect selected types of data frames or packets which are part of read transactions 



which are initiated by at least some of ^aid gead reques ts)originated by a client device 
such that ^i^swit^ rewrites header information in selected types of data frames and 
packets which are part of a read transaction to be rerouted and which correspond to a 



redirection command, ^jdji^er informa tiop) being rewritten such that said selected 
types of data frames and packets are routed throughTsaid switch so as to bypass said 



storage manager in travelling between said client device and(said storage devicejnvolved 



in each(s aid read transaction ^ be rerouted buTsai d rewritin g) of said header information 
of said selected types of data frames and packets which are part of a read transaction to 
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be rerouted (hereafter referred to as relabelled data frames) being such as to make each 



(^i drela belled da ta fram^ jook like it came from said storage manager; 

transmitting a read request corresponding to each read request received by said 
storage manager from a client device to one or more storage devices identified in(said 
Griginai^^ by said storage manager so as to start the read transaction. 



39. (Original) A process of redirecting data frames or packets in a packet or frame 
switched network, said process carried out in a switch and comprising the steps: 

receiving from a storage manager at a packet or frame switch redirection 
commands to redirect the data frames or packets which are responses to at least some of 



said (ead^requests/originated by a client device and storing said redirection commands; 
and 

in said switch, intercepting frames or packets of read data responding to said at 
least some read requests, and, if a redirection command is stored for a read transaction 
which certain packets or frames containing the requested read data are a part of, changing 
the header of the frames or packets of said particular read transaction which contain the 
requested read data so as to reroute them through said switch so as to bypass said storage 
manager but relabelling the headers thereof such that the rerouted packets or frames have 
the Port_ID of the client that made the read request as the destination address and the 
Port_ID of the storage device as the source address and have the originator exchange ID 
originally assigned by said client; and 
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in said client, receiving said frames and mapping them to the original read requests 
sent to said storage manager. 

40. (Original) A process of redirecting data frames or packets in a packet or 
frame switched network comprising the steps: 

receiving at a storage manager from a client computer a write request; 
receiving from a storage manager at a packet or frame switch at least two 
redirection commands to redirect the data and transfer ready frames or packets of<|ai^ 
rite requesPand storing said redirection commands; 



transmitting a corresponding write request from ^jdjrtoragem a storage 

device to get the transaction started; 



at |akl storage ^devi^, responding to said write request by transmitting one or 
more transfer ready frames from said storage device when it is ready to receive at least 
some of the write data, s ddLtransfer ready frame(s) or packet(sTa ddressed to said storage 
manager; and 



in ^ai tf swit ch, intercepting s^ id transfer re ,adyLJ3^m(s)_or packet(sj^ f data 
responding to write request, and, if a redirection command is stored for a write 
transaction which said transfer ready frame(s) or packet(s) are a part of, changing the 



header of the transfer ready frame(s) or packet(s) of <0d write transaction^ be redirected 




and routing transfer ready frame(s) or packet(s) so as to reroute them through said switch 
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so as to bypass said storage manager but so as to appear that transfer ready frame(s) or 
packet(s) originated from said storage manager; 



at-^d client d evice) receiving transfer ready frame(s) or packet(s) and responding 



by sending one or more frames or packets of write data to said switch; 

at said switch, receiving said one or more frames or packets of write data and if a 



redirection command is stored for a write transaction which^aid (Write data frame(sW)r 



packet(s) are a part of, changing the header of the write data frame(s) or packet(s) of said 
write transaction to be redirected and routing said write data frame(s) or packet(s) so as to 



originated from said storage manager; and 

continuing the process re-routing said transfer ready and write data frames until 
the entire write transaction is completed. 

4J. (Original) A process of redirecting data frames or packets in a packet or 
frame switched network, said process carried out in a switch and comprising the steps: 

receiving from a storage manager at a packet or frame switch one or more 
redirection commands to redirect the data and transfer ready frames or packets which are 



part of a write transaction originated by a client_de}^e) and storing said redirection 
commands; and 

in said switch, intercepting write]5ata an^transfer ready frames or packetsjwhich 
are part of a write transaction to be redirected and, if one or more redirection commands 





bypass said storage manager but so as to appear that write data frame(s) or packet(s) 
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have been stored for the write transaction of which said write data and transfer ready 
frames or packets are a part, changing the header of the write data and transfer ready 
frames or packets so as to reroute them through said switch so as to bypass <<md storage 
/fnMager^t so as to look like they came from said storage manager and so as to have the 



originator exchange ID originally assigned by said client to the write transaction; and 



transmitting s&d writej iata and transfer rea d y fram ^ or packets to (said client or 
said-storage deviciTas appropriate. 

42. (Previously Amended) A system comprising: 
a data path or paths; 

one or more client devices coupled to said data path(s); 
one or more storage devices coupled to said data path(s); 

one or more sw itch means coupled said data path(s) for receiving packets or 
frames and routing them appropriately according to header address information in(§akT) 
jackets or frames, and for receiving redirection commands and storing them in one or 
more lookup tables and for using old and new address data iri ^icfredirection comm aads> 
to determine which packets or frames of all the packets and frames processed by(said 
^wkc^jneans) are part of a read or write transaction to be redirected and for using 
information in said redirection commands to rewrite headers in said packets or frames to 
be redirected so as to cause said packets or frames to be rerouted to pass between a client 
device and a storage device via said switch means without the need to be routed to a 
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storage manager thereby bypassingfl^aicf storage managerJbuHfaid rewriting > o^aict 




leadersjbeing done so as to make each rerouted packet or frame appear as if it was 
transmitted by said storage manager, and for receiving purge commands and for using the 



data i^aid^purge^^ purge from said^one^o r more loo kup ta5le^ redirection 

commands for read and/or write transactions that have been completed; and 



storage manager means for receiving read and/or write requests from ^aid one or ^> 
\more ^i^nt^evicps and for determining by any means whether or not to redirect 



predetermined type of packets or frames in read or write transactions initiated by (said^) 
< ^ €ad^ ^r write request^, and, if a transaction initiated by a read and/or write request is 
to be redirected, for generating and sending to said switch means said one or more 
redirection commands to cause predetermined types of packets or frames of said read 
and/or write transactions to be redirected so as to bypass said storage manager means but 
to appear as if said predetermined types of packets or frames that were rerouted appear as 
if they did not bypass said storage manager means, and for determining when a read 
and/or write transaction that has been redirected has been completed and for generating 
one or more said purge commands pertaining to said read and/or write transactions that 
have been completed, and sending said purge commands to said switch means to cause it 
to purge the redirection commands of completed transactions, and, if a read or write 
transaction is not to be redirected, for processing it conventionally. 
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43. (Original) A switch for a packet switched or frame switched network, said 
switch having conventional routing circuitry, said network having client devices and 
storage devices and a storage manager that decides to redirect read and/or write 
transactions on any basis so as to virtualize said storage devices, said switch comprising: 

one or more ports which are structured to operate to receive one or more 
redirection commands from said storage manager or another switch in said network 
coupled to said storage manager containing old address data and new address dataTsaict" 



ports) containing circuitry to store (£aid old address data and new addresTdii^of ^aidTon^> 



or more redirection commands) in one or more look up tables, said switch containing 



circuitry functioning to compare packet or frame type information included in a header of 
at least some packets or frames arriving at a port coupled to a client device or a storage 
device to determine if the packet or frame is of a type which is to be relabelled and 
redirected, and, if the packet or frame is of a type to be relabelled and redirected, 
comparing at least some of the old address data therein to the old address data entries for 
one or more redirection commands stored in one or more of said look up tables, and if 
there is a match to any of the old address data of said one or more redirection commands, 
relabelling said packet or frame by substituting the corresponding new address data from 



saidjna tohing r edirectio^ for said old address data in said packet or frame 

header, said new address data being such as to cause said relabelled packet or frame to be 
routed so as to bypass said storage manager but to look like it came from said storage 
manager, and then passing said relabelled packet or frame to said conventional routing 
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circuitry for forwarding to the destination identified in said new address data, each port 
further comprising circuitry to recognize incoming status frames indicating that a 
particular read or write transaction has been completed and to respond thereto by 
automatically purging from one or more lookup tables one or more redirection commands 
that pertain to the completed transaction of which ^^'status frames a part and route 
said status frame to a port of said switch coupled to a storage manager, and wherein the 
sequence in which the type of incoming packet is determined and the old address data 
lookup is performed is not critical. 
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